Functions
library(stringi)
library(reticulate)
library(ggplotify)
source_from_github(repositoy = "DEG_functions",version = "0.2.47")
ℹ SHA-1 hash of file is f5bb1cd741d13bded83fe3b6fd43169e29731216
Welcome to enrichR
Checking connection ...
Enrichr ... Connection is Live!
FlyEnrichr ... Connection is available!
WormEnrichr ... Connection is available!
YeastEnrichr ... Connection is available!
FishEnrichr ... Connection is available!
source_from_github(repositoy = "cNMF_functions",version = "0.4.04",script_name = "cnmf_functions_V3.R")
ℹ SHA-1 hash of file is a735d9bfb5bc55fcb203f83a7240b9713fc080d3
source_from_github(repositoy = "sc_general_functions",version = "0.1.34",script_name = "functions.R")
ℹ SHA-1 hash of file is 55839fb7db3fdb3e61d8d423b0b3129bfa1d777b
Data
xeno <- qs::qread("./raw_data/xeno.qs")
DE pathways
pathwayScoresMatrix = read_rds(file = "./output_data/run_SiPSiC/pathwayScoresMatrix.RDS")
xeno[["sipsic"]] = CreateAssayObject(counts = pathwayScoresMatrix)
Warning: Feature names cannot have underscores ('_'), replacing with dashes ('-')
trace(Seurat:::FindMarkers.default,edit = T) #replace "bonferroni" with "fdr"
Warning in edit.default(def, editor = editor, file = file) :
deparse may be incomplete
Tracing function "FindMarkers.default" in package "Seurat (not-exported)"
[1] "FindMarkers.default"
xeno = SetIdent(xeno, value = "treatment")
pathways_names = gsub(rownames(pathwayScoresMatrix), pattern = "_", replacement = "-")
logFC_df = data.frame(row.names = pathways_names)
fdr_df = data.frame(row.names = pathways_names)
for (model in unique(xeno$orig.ident)) {
model_data = subset(xeno, subset = orig.ident == model)
pathway_markers = FindMarkers(
object = model_data,
ident.1 = "OSI",
ident.2 = "NT",
assay = "sipsic",
slot = "counts",
logfc.threshold = 0,
densify = T,
pseudocount.use = 0.001,
features = pathways_names
)
avg_log2FC = pathway_markers[pathways_names, "avg_log2FC", drop = F]
colnames(avg_log2FC) = model
pathway_markers %<>% dplyr::rename(fdr = p_val_adj)
fdr = pathway_markers[pathways_names, "fdr", drop = F]
colnames(fdr) = model
logFC_df = cbind(logFC_df, avg_log2FC)
fdr_df = cbind(fdr_df, fdr)
}
| | 0 % ~calculating
|+ | 2 % ~01s
|++ | 4 % ~01s
|+++ | 6 % ~01s
|++++ | 8 % ~01s
|+++++ | 10% ~01s
|++++++ | 12% ~01s
|+++++++ | 14% ~01s
|++++++++ | 16% ~00s
|+++++++++ | 18% ~00s
|++++++++++ | 20% ~00s
|+++++++++++ | 22% ~00s
|++++++++++++ | 24% ~00s
|+++++++++++++ | 26% ~00s
|++++++++++++++ | 28% ~00s
|+++++++++++++++ | 30% ~00s
|++++++++++++++++ | 32% ~00s
|+++++++++++++++++ | 34% ~00s
|++++++++++++++++++ | 36% ~00s
|+++++++++++++++++++ | 38% ~00s
|++++++++++++++++++++ | 40% ~00s
|+++++++++++++++++++++ | 42% ~00s
|++++++++++++++++++++++ | 44% ~00s
|+++++++++++++++++++++++ | 46% ~00s
|++++++++++++++++++++++++ | 48% ~00s
|+++++++++++++++++++++++++ | 50% ~00s
|++++++++++++++++++++++++++ | 52% ~00s
|+++++++++++++++++++++++++++ | 54% ~00s
|++++++++++++++++++++++++++++ | 56% ~00s
|+++++++++++++++++++++++++++++ | 58% ~00s
|++++++++++++++++++++++++++++++ | 60% ~00s
|+++++++++++++++++++++++++++++++ | 62% ~00s
|++++++++++++++++++++++++++++++++ | 64% ~00s
|+++++++++++++++++++++++++++++++++ | 66% ~00s
|++++++++++++++++++++++++++++++++++ | 68% ~00s
|+++++++++++++++++++++++++++++++++++ | 70% ~00s
|++++++++++++++++++++++++++++++++++++ | 72% ~00s
|+++++++++++++++++++++++++++++++++++++ | 74% ~00s
|++++++++++++++++++++++++++++++++++++++ | 76% ~00s
|+++++++++++++++++++++++++++++++++++++++ | 78% ~00s
|++++++++++++++++++++++++++++++++++++++++ | 80% ~00s
|+++++++++++++++++++++++++++++++++++++++++ | 82% ~00s
|++++++++++++++++++++++++++++++++++++++++++ | 84% ~00s
|+++++++++++++++++++++++++++++++++++++++++++ | 86% ~00s
|++++++++++++++++++++++++++++++++++++++++++++ | 88% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++ | 90% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++ | 92% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++ | 94% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++ | 96% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++++ | 98% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++++| 100% elapsed=00s
| | 0 % ~calculating
|+ | 2 % ~01s
|++ | 4 % ~01s
|+++ | 6 % ~00s
|++++ | 8 % ~01s
|+++++ | 10% ~01s
|++++++ | 12% ~01s
|+++++++ | 14% ~01s
|++++++++ | 16% ~01s
|+++++++++ | 18% ~01s
|++++++++++ | 20% ~01s
|+++++++++++ | 22% ~01s
|++++++++++++ | 24% ~00s
|+++++++++++++ | 26% ~00s
|++++++++++++++ | 28% ~00s
|+++++++++++++++ | 30% ~00s
|++++++++++++++++ | 32% ~00s
|+++++++++++++++++ | 34% ~00s
|++++++++++++++++++ | 36% ~00s
|+++++++++++++++++++ | 38% ~00s
|++++++++++++++++++++ | 40% ~00s
|+++++++++++++++++++++ | 42% ~00s
|++++++++++++++++++++++ | 44% ~00s
|+++++++++++++++++++++++ | 46% ~00s
|++++++++++++++++++++++++ | 48% ~00s
|+++++++++++++++++++++++++ | 50% ~00s
|++++++++++++++++++++++++++ | 52% ~00s
|+++++++++++++++++++++++++++ | 54% ~00s
|++++++++++++++++++++++++++++ | 56% ~00s
|+++++++++++++++++++++++++++++ | 58% ~00s
|++++++++++++++++++++++++++++++ | 60% ~00s
|+++++++++++++++++++++++++++++++ | 62% ~00s
|++++++++++++++++++++++++++++++++ | 64% ~00s
|+++++++++++++++++++++++++++++++++ | 66% ~00s
|++++++++++++++++++++++++++++++++++ | 68% ~00s
|+++++++++++++++++++++++++++++++++++ | 70% ~00s
|++++++++++++++++++++++++++++++++++++ | 72% ~00s
|+++++++++++++++++++++++++++++++++++++ | 74% ~00s
|++++++++++++++++++++++++++++++++++++++ | 76% ~00s
|+++++++++++++++++++++++++++++++++++++++ | 78% ~00s
|++++++++++++++++++++++++++++++++++++++++ | 80% ~00s
|+++++++++++++++++++++++++++++++++++++++++ | 82% ~00s
|++++++++++++++++++++++++++++++++++++++++++ | 84% ~00s
|+++++++++++++++++++++++++++++++++++++++++++ | 86% ~00s
|++++++++++++++++++++++++++++++++++++++++++++ | 88% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++ | 90% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++ | 92% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++ | 94% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++ | 96% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++++ | 98% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++++| 100% elapsed=01s
| | 0 % ~calculating
|+ | 2 % ~01s
|++ | 4 % ~01s
|+++ | 6 % ~01s
|++++ | 8 % ~01s
|+++++ | 10% ~01s
|++++++ | 12% ~01s
|+++++++ | 14% ~01s
|++++++++ | 16% ~01s
|+++++++++ | 18% ~01s
|++++++++++ | 20% ~00s
|+++++++++++ | 22% ~00s
|++++++++++++ | 24% ~00s
|+++++++++++++ | 26% ~00s
|++++++++++++++ | 28% ~00s
|+++++++++++++++ | 30% ~00s
|++++++++++++++++ | 32% ~00s
|+++++++++++++++++ | 34% ~00s
|++++++++++++++++++ | 36% ~00s
|+++++++++++++++++++ | 38% ~00s
|++++++++++++++++++++ | 40% ~00s
|+++++++++++++++++++++ | 42% ~00s
|++++++++++++++++++++++ | 44% ~00s
|+++++++++++++++++++++++ | 46% ~00s
|++++++++++++++++++++++++ | 48% ~00s
|+++++++++++++++++++++++++ | 50% ~00s
|++++++++++++++++++++++++++ | 52% ~00s
|+++++++++++++++++++++++++++ | 54% ~00s
|++++++++++++++++++++++++++++ | 56% ~00s
|+++++++++++++++++++++++++++++ | 58% ~00s
|++++++++++++++++++++++++++++++ | 60% ~00s
|+++++++++++++++++++++++++++++++ | 62% ~00s
|++++++++++++++++++++++++++++++++ | 64% ~00s
|+++++++++++++++++++++++++++++++++ | 66% ~00s
|++++++++++++++++++++++++++++++++++ | 68% ~00s
|+++++++++++++++++++++++++++++++++++ | 70% ~00s
|++++++++++++++++++++++++++++++++++++ | 72% ~00s
|+++++++++++++++++++++++++++++++++++++ | 74% ~00s
|++++++++++++++++++++++++++++++++++++++ | 76% ~00s
|+++++++++++++++++++++++++++++++++++++++ | 78% ~00s
|++++++++++++++++++++++++++++++++++++++++ | 80% ~00s
|+++++++++++++++++++++++++++++++++++++++++ | 82% ~00s
|++++++++++++++++++++++++++++++++++++++++++ | 84% ~00s
|+++++++++++++++++++++++++++++++++++++++++++ | 86% ~00s
|++++++++++++++++++++++++++++++++++++++++++++ | 88% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++ | 90% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++ | 92% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++ | 94% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++ | 96% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++++ | 98% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++++| 100% elapsed=01s
| | 0 % ~calculating
|+ | 2 % ~01s
|++ | 4 % ~01s
|+++ | 6 % ~01s
|++++ | 8 % ~01s
|+++++ | 10% ~01s
|++++++ | 12% ~01s
|+++++++ | 14% ~01s
|++++++++ | 16% ~01s
|+++++++++ | 18% ~01s
|++++++++++ | 20% ~01s
|+++++++++++ | 22% ~01s
|++++++++++++ | 24% ~01s
|+++++++++++++ | 26% ~01s
|++++++++++++++ | 28% ~01s
|+++++++++++++++ | 30% ~00s
|++++++++++++++++ | 32% ~00s
|+++++++++++++++++ | 34% ~00s
|++++++++++++++++++ | 36% ~00s
|+++++++++++++++++++ | 38% ~00s
|++++++++++++++++++++ | 40% ~00s
|+++++++++++++++++++++ | 42% ~00s
|++++++++++++++++++++++ | 44% ~00s
|+++++++++++++++++++++++ | 46% ~00s
|++++++++++++++++++++++++ | 48% ~00s
|+++++++++++++++++++++++++ | 50% ~00s
|++++++++++++++++++++++++++ | 52% ~00s
|+++++++++++++++++++++++++++ | 54% ~00s
|++++++++++++++++++++++++++++ | 56% ~00s
|+++++++++++++++++++++++++++++ | 58% ~00s
|++++++++++++++++++++++++++++++ | 60% ~00s
|+++++++++++++++++++++++++++++++ | 62% ~00s
|++++++++++++++++++++++++++++++++ | 64% ~00s
|+++++++++++++++++++++++++++++++++ | 66% ~00s
|++++++++++++++++++++++++++++++++++ | 68% ~00s
|+++++++++++++++++++++++++++++++++++ | 70% ~00s
|++++++++++++++++++++++++++++++++++++ | 72% ~00s
|+++++++++++++++++++++++++++++++++++++ | 74% ~00s
|++++++++++++++++++++++++++++++++++++++ | 76% ~00s
|+++++++++++++++++++++++++++++++++++++++ | 78% ~00s
|++++++++++++++++++++++++++++++++++++++++ | 80% ~00s
|+++++++++++++++++++++++++++++++++++++++++ | 82% ~00s
|++++++++++++++++++++++++++++++++++++++++++ | 84% ~00s
|+++++++++++++++++++++++++++++++++++++++++++ | 86% ~00s
|++++++++++++++++++++++++++++++++++++++++++++ | 88% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++ | 90% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++ | 92% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++ | 94% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++ | 96% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++++ | 98% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++++| 100% elapsed=01s
| | 0 % ~calculating
|+ | 2 % ~01s
|++ | 4 % ~01s
|+++ | 6 % ~01s
|++++ | 8 % ~01s
|+++++ | 10% ~01s
|++++++ | 12% ~01s
|+++++++ | 14% ~01s
|++++++++ | 16% ~01s
|+++++++++ | 18% ~01s
|++++++++++ | 20% ~01s
|+++++++++++ | 22% ~01s
|++++++++++++ | 24% ~01s
|+++++++++++++ | 26% ~00s
|++++++++++++++ | 28% ~00s
|+++++++++++++++ | 30% ~00s
|++++++++++++++++ | 32% ~00s
|+++++++++++++++++ | 34% ~00s
|++++++++++++++++++ | 36% ~00s
|+++++++++++++++++++ | 38% ~00s
|++++++++++++++++++++ | 40% ~00s
|+++++++++++++++++++++ | 42% ~00s
|++++++++++++++++++++++ | 44% ~00s
|+++++++++++++++++++++++ | 46% ~00s
|++++++++++++++++++++++++ | 48% ~00s
|+++++++++++++++++++++++++ | 50% ~00s
|++++++++++++++++++++++++++ | 52% ~00s
|+++++++++++++++++++++++++++ | 54% ~00s
|++++++++++++++++++++++++++++ | 56% ~00s
|+++++++++++++++++++++++++++++ | 58% ~00s
|++++++++++++++++++++++++++++++ | 60% ~00s
|+++++++++++++++++++++++++++++++ | 62% ~00s
|++++++++++++++++++++++++++++++++ | 64% ~00s
|+++++++++++++++++++++++++++++++++ | 66% ~00s
|++++++++++++++++++++++++++++++++++ | 68% ~00s
|+++++++++++++++++++++++++++++++++++ | 70% ~00s
|++++++++++++++++++++++++++++++++++++ | 72% ~00s
|+++++++++++++++++++++++++++++++++++++ | 74% ~00s
|++++++++++++++++++++++++++++++++++++++ | 76% ~00s
|+++++++++++++++++++++++++++++++++++++++ | 78% ~00s
|++++++++++++++++++++++++++++++++++++++++ | 80% ~00s
|+++++++++++++++++++++++++++++++++++++++++ | 82% ~00s
|++++++++++++++++++++++++++++++++++++++++++ | 84% ~00s
|+++++++++++++++++++++++++++++++++++++++++++ | 86% ~00s
|++++++++++++++++++++++++++++++++++++++++++++ | 88% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++ | 90% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++ | 92% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++ | 94% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++ | 96% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++++ | 98% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++++| 100% elapsed=01s
| | 0 % ~calculating
|+ | 2 % ~01s
|++ | 4 % ~00s
|+++ | 6 % ~00s
|++++ | 8 % ~00s
|+++++ | 10% ~00s
|++++++ | 12% ~00s
|+++++++ | 14% ~00s
|++++++++ | 16% ~00s
|+++++++++ | 18% ~00s
|++++++++++ | 20% ~00s
|+++++++++++ | 22% ~00s
|++++++++++++ | 24% ~00s
|+++++++++++++ | 26% ~00s
|++++++++++++++ | 28% ~00s
|+++++++++++++++ | 30% ~00s
|++++++++++++++++ | 32% ~00s
|+++++++++++++++++ | 34% ~00s
|++++++++++++++++++ | 36% ~00s
|+++++++++++++++++++ | 38% ~00s
|++++++++++++++++++++ | 40% ~00s
|+++++++++++++++++++++ | 42% ~00s
|++++++++++++++++++++++ | 44% ~00s
|+++++++++++++++++++++++ | 46% ~00s
|++++++++++++++++++++++++ | 48% ~00s
|+++++++++++++++++++++++++ | 50% ~00s
|++++++++++++++++++++++++++ | 52% ~00s
|+++++++++++++++++++++++++++ | 54% ~00s
|++++++++++++++++++++++++++++ | 56% ~00s
|+++++++++++++++++++++++++++++ | 58% ~00s
|++++++++++++++++++++++++++++++ | 60% ~00s
|+++++++++++++++++++++++++++++++ | 62% ~00s
|++++++++++++++++++++++++++++++++ | 64% ~00s
|+++++++++++++++++++++++++++++++++ | 66% ~00s
|++++++++++++++++++++++++++++++++++ | 68% ~00s
|+++++++++++++++++++++++++++++++++++ | 70% ~00s
|++++++++++++++++++++++++++++++++++++ | 72% ~00s
|+++++++++++++++++++++++++++++++++++++ | 74% ~00s
|++++++++++++++++++++++++++++++++++++++ | 76% ~00s
|+++++++++++++++++++++++++++++++++++++++ | 78% ~00s
|++++++++++++++++++++++++++++++++++++++++ | 80% ~00s
|+++++++++++++++++++++++++++++++++++++++++ | 82% ~00s
|++++++++++++++++++++++++++++++++++++++++++ | 84% ~00s
|+++++++++++++++++++++++++++++++++++++++++++ | 86% ~00s
|++++++++++++++++++++++++++++++++++++++++++++ | 88% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++ | 90% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++ | 92% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++ | 94% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++ | 96% ~00s
|+++++++++++++++++++++++++++++++++++++++++++++++++ | 98% ~00s
|++++++++++++++++++++++++++++++++++++++++++++++++++| 100% elapsed=00s
fdr_df_raw = fdr_df
fdr_df = apply(fdr_df, 1:2, \(x) format(x, digits=1)) %>% as.data.frame() #round p values
fdr_df[fdr_df == 0] = paste0("<",format(.Machine$double.xmin,digits = 1)) # replace p=0 with p<min float
untrace(Seurat:::FindMarkers.default)
Untracing function "FindMarkers.default" in package "Seurat (not-exported)"
# color row name if consistent across patients/models
colors= c()
for (row_num in 1:nrow(logFC_df)) {
row = logFC_df[row_num,]
if (sum(row > 0.15) >= 4) { # if at least x values are more than 0.1 log2FC
colors <- c(colors, "red")
}
else if (sum(row < -0.15) >= 4) {
colors <- c(colors, "blue")
}
else{colors <- c(colors, "black")}
}
col_fun = circlize::colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
p = ComplexHeatmap::Heatmap(logFC_df, name = "log2FC on/pre", col = col_fun,
cell_fun = function(j, i, x, y, width, height, fill) {
grid.text(fdr_df[i, j], x, y, gp = gpar(fontsize = 8))
}, row_names_gp = gpar(fontsize = 8,col =colors), clustering_method_rows = "average", clustering_distance_rows = "euclidean")
Warning: The input is a data frame, convert it to a matrix.
p
Warning in grSoftVersion() :
unable to load shared object '/usr/local/lib/R/modules//R_X11.so':
libXt.so.6: cannot open shared object file: No such file or directory

```r
saveRDS(object = as.grob(p),file = \./Figures/xeno_sipsic_heatmap.rds\)
<!-- rnb-source-end -->
<!-- rnb-output-end -->
<!-- rnb-chunk-end -->
<!-- rnb-text-begin -->
# Heatmap with asterisks
<!-- rnb-text-end -->
<!-- rnb-chunk-begin -->
<!-- rnb-output-begin eyJkYXRhIjoiXG48IS0tIHJuYi1zb3VyY2UtYmVnaW4gZXlKa1lYUmhJam9pWUdCZ2NseHVJeUJFWlhOamNtbHdkR2x2Ymx4dVptUnlYMlJtWDNOcFp5QTlJR1prY2w5a1psOXlZWGRjYm1aa2NsOWtabDl6YVdkYlhTQThMU0JzWVhCd2JIa29abVJ5WDJSbVgzTnBaeXdnWVhNdWJuVnRaWEpwWXlsY2JseHVZMjl1ZG1WeWRDQThMU0JtZFc1amRHbHZiaWgyWldNcElIdGNiaUFnYzNsdGJuVnRLSFpsWXl3Z1kyOXljaUE5SUVaQlRGTkZMQ0J1WVNBOUlFWkJURk5GTENCamRYUndiMmx1ZEhNZ1BTQmpLREFzSUZ4dUlDQWdJREF1TURBeExDQXdMakF4TENBd0xqQTFMQ0F3TGpFc0lERXBMQ0J6ZVcxaWIyeHpJRDBnWXloY0lpb3FLbHdpTENCY0lpb3FYQ0lzSUZ3aUtsd2lMQ0JjSWk1Y0lpd2dYQ0lnWENJcEtTQWxQaVVnWVhNdVkyaGhjbUZqZEdWeUtDbGNibjBnWEc1Y2JtWmtjbDlrWmw5emFXZGJYU0E5SUdGd2NHeDVLR1prY2w5a1psOXphV2NzSUUxQlVrZEpUaUE5SURFc0lFWlZUaUE5SUdOdmJuWmxjblFwWEc1Z1lHQWlmUT09IC0tPlxuXG5gYGByXG4jIERlc2NyaXB0aW9uXG5mZHJfZGZfc2lnID0gZmRyX2RmX3Jhd1xuZmRyX2RmX3NpZ1tdIDwtIGxhcHBseShmZHJfZGZfc2lnLCBhcy5udW1lcmljKVxuXG5jb252ZXJ0IDwtIGZ1bmN0aW9uKHZlYykge1xuICBzeW1udW0odmVjLCBjb3JyID0gRkFMU0UsIG5hID0gRkFMU0UsIGN1dHBvaW50cyA9IGMoMCwgXG4gICAgMC4wMDEsIDAuMDEsIDAuMDUsIDAuMSwgMSksIHN5bWJvbHMgPSBjKFwiKioqXCIsIFwiKipcIiwgXCIqXCIsIFwiLlwiLCBcIiBcIikpICU+JSBhcy5jaGFyYWN0ZXIoKVxufSBcblxuZmRyX2RmX3NpZ1tdID0gYXBwbHkoZmRyX2RmX3NpZywgTUFSR0lOID0gMSwgRlVOID0gY29udmVydClcbmBgYFxuXG48IS0tIHJuYi1zb3VyY2UtZW5kIC0tPlxuIn0= -->
<!-- rnb-source-begin eyJkYXRhIjoiYGBgclxuIyBEZXNjcmlwdGlvblxuZmRyX2RmX3NpZyA9IGZkcl9kZl9yYXdcbmZkcl9kZl9zaWdbXSA8LSBsYXBwbHkoZmRyX2RmX3NpZywgYXMubnVtZXJpYylcblxuY29udmVydCA8LSBmdW5jdGlvbih2ZWMpIHtcbiAgc3ltbnVtKHZlYywgY29yciA9IEZBTFNFLCBuYSA9IEZBTFNFLCBjdXRwb2ludHMgPSBjKDAsIFxuICAgIDAuMDAxLCAwLjAxLCAwLjA1LCAwLjEsIDEpLCBzeW1ib2xzID0gYyhcIioqKlwiLCBcIioqXCIsIFwiKlwiLCBcIi5cIiwgXCIgXCIpKSAlPiUgYXMuY2hhcmFjdGVyKClcbn0gXG5cbmZkcl9kZl9zaWdbXSA9IGFwcGx5KGZkcl9kZl9zaWcsIE1BUkdJTiA9IDEsIEZVTiA9IGNvbnZlcnQpXG5gYGAifQ== -->
```r
# Description
fdr_df_sig = fdr_df_raw
fdr_df_sig[] <- lapply(fdr_df_sig, as.numeric)
convert <- function(vec) {
symnum(vec, corr = FALSE, na = FALSE, cutpoints = c(0,
0.001, 0.01, 0.05, 0.1, 1), symbols = c("***", "**", "*", ".", " ")) %>% as.character()
}
fdr_df_sig[] = apply(fdr_df_sig, MARGIN = 1, FUN = convert)
col_fun = circlize::colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
p = ComplexHeatmap::Heatmap(logFC_df, name = "log2FC on/pre", col = col_fun,
cell_fun = function(j, i, x, y, width, height, fill) {
grid.text(fdr_df_sig[i, j], x, y, gp = gpar(fontsize = 8))
}, row_names_gp = gpar(fontsize = 8,col =colors), clustering_method_rows = "average", clustering_distance_rows = "euclidean")
Warning: The input is a data frame, convert it to a matrix.
p

Heatmap
DefaultAssay(xeno) = "sipsic"
data = FetchData(object = xeno, vars = c(pathways_names,"orig.ident"))
data[] <- data %>% group_by(orig.ident) %>% mutate(across(is.numeric, ~ as.numeric(scale(.)))) %>% ungroup()
data = data %>% select(-orig.ident)
data = data %>% t() %>% as.data.frame()
annotation_data = FetchData(object = xeno, vars = c("orig.ident","treatment")) %>% dplyr::arrange(orig.ident,treatment)
column_ha = HeatmapAnnotation(df = annotation_data[,2])
data = data[,rownames(annotation_data)] #order data like annotation
data = na.omit(data)
p = ComplexHeatmap::Heatmap(
data,
show_column_names = F,
row_names_gp = grid::gpar(fontsize = 7),
cluster_rows = T,
top_annotation = column_ha,
name = "Z-score expression",use_raster = F,cluster_columns = F,column_split = annotation_data$orig.ident,
column_gap = unit(2, "mm"), border = TRUE,show_parent_dend_line = FALSE, show_column_dend = FALSE,cluster_column_slices = F
)
Warning: The input is a data frame, convert it to a matrix.
The automatically generated colors map from the minus and plus 99^th of the absolute values in the
matrix. There are outliers in the matrix whose patterns might be hidden by this color mapping. You can
manually set the color to `col` argument.
Use `suppressMessages()` to turn off this message.
p

# heatmap with clutering per model and time point
DefaultAssay(xeno) = "sipsic"
data = FetchData(object = xeno, vars = c(pathways_names,"orig.ident"))
data[] <- data %>% group_by(orig.ident) %>%
mutate(across(is.numeric, ~ as.numeric(scale(.)))) %>% ungroup() # scale per model
Warning: Problem while computing `..1 = across(is.numeric, ~as.numeric(scale(.)))`.
ℹ Predicate functions must be wrapped in `where()`.
# Bad data %>% select(is.numeric)
# Good data %>% select(where(is.numeric))
ℹ Please update your code. This message is displayed once per session.
ℹ The warning occurred in group 0: character(0).
data = data %>% select(-orig.ident) # remove ident var
data = data %>% t() %>% as.data.frame()
annotation_data = FetchData(object = xeno, vars = c("orig.ident","treatment")) %>% dplyr::arrange(orig.ident,treatment)
column_ha = HeatmapAnnotation(Treatment = annotation_data[,2], #set annotation
col = list(Treatment = c("NT" = "red", "OSI" = "green", "res" = "blue")))
data = data[,rownames(annotation_data)] #order data like annotation
data = na.omit(data)
column_split = paste(annotation_data$orig.ident,annotation_data$treatment,sep = "\n") #split by ident+tp
column_names = unique(column_split) %>% gsub(pattern = "119\nOSI",replacement = " 119\n OSI") #adujst location to avoid overlap
DefaultAssay(xeno) = "RNA" #make RNA default again
p = ComplexHeatmap::Heatmap(
data,
show_column_names = F,
row_names_gp = grid::gpar(fontsize = 10),
cluster_rows = T,
top_annotation = column_ha,
name = "Z-score expression",use_raster = F,cluster_columns = T,column_split = column_split,
column_title = column_names,
column_gap = unit(2, "mm"), border = TRUE,show_parent_dend_line = FALSE, show_column_dend = F,cluster_column_slices = F)
Warning: The input is a data frame, convert it to a matrix.
The automatically generated colors map from the minus and plus 99^th of the absolute values in the matrix. There are outliers
in the matrix whose patterns might be hidden by this color mapping. You can manually set the color to `col` argument.
Use `suppressMessages()` to turn off this message.
p

# only nmf programs
for (patient_name in unique(xeno$orig.ident)) {
patient_data = subset(xeno,subset = orig.ident == patient_name)
pathways_names = c("HALLMARK-INTERFERON-ALPHA-RESPONSE","HALLMARK-TNFA-SIGNALING-VIA-NFKB", "HALLMARK-HYPOXIA","HALLMARK-E2F-TARGETS" )
DefaultAssay(patient_data) = "sipsic"
data = FetchData(object = patient_data, vars = c(pathways_names))
data[] <- data %>%
mutate(across(everything(), ~ as.numeric(scale(.)))) # scale per pathway
data = data %>% t() %>% as.data.frame()
annotation_data = FetchData(object = patient_data, vars = c("treatment")) %>% dplyr::arrange(treatment)
column_ha = HeatmapAnnotation(Treatment = annotation_data[,1], #set annotation
col = list(Treatment = c("NT" = "red", "OSI" = "green", "res" = "blue")))
data = data[,rownames(annotation_data)] #order data like annotation
data = na.omit(data)
DefaultAssay(xeno) = "RNA" #make RNA default again
p = ComplexHeatmap::Heatmap(
data,
show_column_names = F,
row_names_gp = grid::gpar(fontsize = 10),
cluster_rows = T,
top_annotation = column_ha,
name = "Z-score expression",use_raster = F,cluster_columns = T,column_split = annotation_data$treatment,
column_gap = unit(2, "mm"), border = TRUE,show_parent_dend_line = FALSE, show_column_dend = T,cluster_column_slices = F,column_title = patient_name)
print(p)
}
Warning: The input is a data frame, convert it to a matrix.
Warning in grSoftVersion() :
unable to load shared object '/usr/local/lib/R/modules//R_X11.so':
libXt.so.6: cannot open shared object file: No such file or directory
Warning: The input is a data frame, convert it to a matrix.
The automatically generated colors map from the minus and plus 99^th of the absolute values in the matrix. There are outliers
in the matrix whose patterns might be hidden by this color mapping. You can manually set the color to `col` argument.
Use `suppressMessages()` to turn off this message.
Warning: The input is a data frame, convert it to a matrix.
The automatically generated colors map from the minus and plus 99^th of the absolute values in the matrix. There are outliers
in the matrix whose patterns might be hidden by this color mapping. You can manually set the color to `col` argument.
Use `suppressMessages()` to turn off this message.
Warning: The input is a data frame, convert it to a matrix.
Warning: The input is a data frame, convert it to a matrix.
The automatically generated colors map from the minus and plus 99^th of the absolute values in the matrix. There are outliers
in the matrix whose patterns might be hidden by this color mapping. You can manually set the color to `col` argument.
Use `suppressMessages()` to turn off this message.
Warning: The input is a data frame, convert it to a matrix.
The automatically generated colors map from the minus and plus 99^th of the absolute values in the matrix. There are outliers
in the matrix whose patterns might be hidden by this color mapping. You can manually set the color to `col` argument.
Use `suppressMessages()` to turn off this message.






Correlation
# Description
for (patient_name in unique(xeno$orig.ident)) {
patient_data = subset(xeno, subset = orig.ident == patient_name)
pathways_names = c(
"HALLMARK-INTERFERON-ALPHA-RESPONSE",
"HALLMARK-TNFA-SIGNALING-VIA-NFKB",
"HALLMARK-HYPOXIA",
"HALLMARK-E2F-TARGETS"
)
DefaultAssay(patient_data) = "sipsic"
data = FetchData(object = patient_data, vars = c(pathways_names))
data[] <- data %>%
mutate(across(everything(), ~ as.numeric(scale(.)))) # scale per pathway
data = na.omit(data)
DefaultAssay(xeno) = "RNA" #make RNA default again
colnames(data) = c("H_INFa", "H_TNFa_NFKb", "H_HYPOXIA", "H_E2F")
library(circlize)
data = cor(data)
col_fun = colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
p = Heatmap(
data, name = "pearson", col = col_fun, show_row_names = F, column_title = patient_name,
cell_fun = function(j, i, x, y, width, height, fill) {
grid.text(as.character(round(data[i, j], digits = 2)), x, y, gp = gpar(fontsize = 10))
}
)
print(p)
}






Ternary plot
p_list
$`119`
$PC9
$`1109`
$`1071`
$`1157`
$`1068`






p_list
$`119`
Warning: Removed 263 rows containing missing values (geom_point).
$PC9
Warning: Removed 4629 rows containing missing values (geom_point).
$`1109`
Warning: Removed 2574 rows containing missing values (geom_point).
$`1071`
Warning: Removed 2918 rows containing missing values (geom_point).
$`1157`
Error in `f()`:
! Insufficient values in manual scale. 3 needed but only 2 provided.
Backtrace:
1. base `<fn>`(x)
2. ggtern:::print.ggplot(x)
4. ggtern:::ggplot_build.ggplot(x)
5. base::lapply(data, ggint$scales_map_df, scales = npscales)
6. ggplot2 FUN(X[[i]], ...)
...
13. ggplot2 FUN(X[[i]], ...)
14. self$map(df[[j]])
15. ggplot2 f(..., self = self)
16. self$palette(n)
17. ggplot2 f(...)





ggtern(data=df,ggtern::aes(x,y,z)) + geom_point()+
theme_tropical(base_size=14)
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"
[1] "not scaling"

# plot
do.call(ggtern::grid.arrange,args = c(p_list,ncol=3))

---
title: '`r rstudioapi::getSourceEditorContext()$path %>% basename() %>% gsub(pattern = "\\.Rmd",replacement = "")`' 
author: "Avishai Wizel"
date: '`r Sys.time()`'
output: 
  html_notebook: 
    code_folding: hide
    toc: yes
    toc_collapse: yes
    toc_float: 
      collapsed: FALSE
    number_sections: true
    toc_depth: 1
---

<style type="text/css">
.main-container {
  max-width: 85% !important;
  margin: auto;
}
</style>


# Functions

```{r}
library(stringi)
library(reticulate)
library(ggplotify)

source_from_github(repositoy = "DEG_functions",version = "0.2.47")
source_from_github(repositoy = "cNMF_functions",version = "0.4.04",script_name = "cnmf_functions_V3.R")
source_from_github(repositoy = "sc_general_functions",version = "0.1.34",script_name = "functions.R")


```

# Data


```{r}
xeno <- qs::qread("./raw_data/xeno.qs")
```


# DE pathways


```{r}
pathwayScoresMatrix = read_rds(file = "./output_data/run_SiPSiC/pathwayScoresMatrix.RDS")
xeno[["sipsic"]] = CreateAssayObject(counts = pathwayScoresMatrix)

```

```{r}
trace(Seurat:::FindMarkers.default,edit = T) #replace "bonferroni" with "fdr"

```

```{r}
xeno = SetIdent(xeno, value = "treatment")
pathways_names = gsub(rownames(pathwayScoresMatrix), pattern = "_", replacement = "-")


logFC_df = data.frame(row.names = pathways_names)
fdr_df = data.frame(row.names = pathways_names)

for (model in unique(xeno$orig.ident)) {
  model_data = subset(xeno, subset = orig.ident == model)
  pathway_markers = FindMarkers(
    object = model_data,
    ident.1 = "OSI",
    ident.2 = "NT",
    assay = "sipsic",
    slot = "counts",
    logfc.threshold = 0,
    densify = T,
    pseudocount.use = 0.001,
    features = pathways_names
  )
  avg_log2FC = pathway_markers[pathways_names, "avg_log2FC", drop = F]
  colnames(avg_log2FC) = model
  pathway_markers  %<>%  dplyr::rename(fdr = p_val_adj)
  fdr = pathway_markers[pathways_names, "fdr", drop = F]
  colnames(fdr) = model
  
  logFC_df = cbind(logFC_df, avg_log2FC)
  fdr_df = cbind(fdr_df, fdr)
}
fdr_df_raw = fdr_df
fdr_df = apply(fdr_df, 1:2, \(x) format(x, digits=1)) %>% as.data.frame() #round p values 
fdr_df[fdr_df == 0] = paste0("<",format(.Machine$double.xmin,digits = 1)) # replace p=0 with p<min float
```
```{r}
untrace(Seurat:::FindMarkers.default)

```



```{r}
# color row name if consistent across patients/models
colors= c()
for (row_num in 1:nrow(logFC_df)) {
  row = logFC_df[row_num,]
  if (sum(row > 0.15)  >= 4) { # if at least x values are more than 0.1 log2FC
    colors <- c(colors, "red")
  }
  else if (sum(row < -0.15)  >= 4) {
    colors <- c(colors, "blue")
  }
  else{colors <- c(colors, "black")}
}

```

```{r fig.height=7, fig.width=8}
col_fun = circlize::colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
p = ComplexHeatmap::Heatmap(logFC_df, name = "log2FC on/pre", col = col_fun,
    cell_fun = function(j, i, x, y, width, height, fill) {
        grid.text(fdr_df[i, j], x, y, gp = gpar(fontsize = 8))
}, row_names_gp = gpar(fontsize = 8,col =colors), clustering_method_rows = "average", clustering_distance_rows = "euclidean")
p
```

```{r}
saveRDS(object = as.grob(p),file = "./Figures/xeno_sipsic_heatmap.rds")
```

# Heatmap with asterisks



```{r}
# Description
fdr_df_sig = fdr_df_raw
fdr_df_sig[] <- lapply(fdr_df_sig, as.numeric)

convert <- function(vec) {
  symnum(vec, corr = FALSE, na = FALSE, cutpoints = c(0, 
    0.001, 0.01, 0.05, 0.1, 1), symbols = c("***", "**", "*", ".", " ")) %>% as.character()
} 

fdr_df_sig[] = apply(fdr_df_sig, MARGIN = 1, FUN = convert)
```


```{r fig.height=7, fig.width=8}
col_fun = circlize::colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
p = ComplexHeatmap::Heatmap(logFC_df, name = "log2FC on/pre", col = col_fun,
    cell_fun = function(j, i, x, y, width, height, fill) {
        grid.text(fdr_df_sig[i, j], x, y, gp = gpar(fontsize = 8))
}, row_names_gp = gpar(fontsize = 8,col =colors), clustering_method_rows = "average", clustering_distance_rows = "euclidean")
p
```

# Heatmap
```{r fig.height=15}
DefaultAssay(xeno) = "sipsic"
data = FetchData(object = xeno, vars = c(pathways_names,"orig.ident"))
data[] <- data %>%  group_by(orig.ident) %>% mutate(across(is.numeric, ~ as.numeric(scale(.)))) %>% ungroup() 
data = data %>% select(-orig.ident) 
data = data %>% t() %>% as.data.frame()

annotation_data = FetchData(object = xeno, vars = c("orig.ident","treatment")) %>% dplyr::arrange(orig.ident,treatment)
column_ha = HeatmapAnnotation(df = annotation_data[,2])
data = data[,rownames(annotation_data)] #order data like annotation
data = na.omit(data)
p = ComplexHeatmap::Heatmap(
  data,
  show_column_names = F,
  row_names_gp = grid::gpar(fontsize = 7),
  cluster_rows = T,
  top_annotation = column_ha,
  name = "Z-score expression",use_raster = F,cluster_columns = F,column_split   = annotation_data$orig.ident,
  column_gap = unit(2, "mm"), border = TRUE,show_parent_dend_line = FALSE, show_column_dend = FALSE,cluster_column_slices = F
)
  
p
```

```{r fig.height=15}
# heatmap with clutering per model and time point
DefaultAssay(xeno) = "sipsic"
data = FetchData(object = xeno, vars = c(pathways_names,"orig.ident"))
data[] <- data %>%  group_by(orig.ident) %>%
  mutate(across(is.numeric, ~ as.numeric(scale(.)))) %>% ungroup() # scale per model
data = data %>% select(-orig.ident) # remove ident var
data = data %>% t() %>% as.data.frame()

annotation_data = FetchData(object = xeno, vars = c("orig.ident","treatment")) %>% dplyr::arrange(orig.ident,treatment)
column_ha = HeatmapAnnotation(Treatment = annotation_data[,2], #set annotation
                              col = list(Treatment = c("NT" = "red", "OSI" = "green", "res" = "blue"))) 
data = data[,rownames(annotation_data)] #order data like annotation
data = na.omit(data)
column_split = paste(annotation_data$orig.ident,annotation_data$treatment,sep = "\n") #split by ident+tp
column_names = unique(column_split) %>% gsub(pattern = "119\nOSI",replacement = "      119\n      OSI") #adujst location to avoid overlap
DefaultAssay(xeno) = "RNA" #make RNA default again

p = ComplexHeatmap::Heatmap(
  data,
  show_column_names = F,
  row_names_gp = grid::gpar(fontsize = 10),
  cluster_rows = T,
  top_annotation = column_ha,
  name = "Z-score expression",use_raster = F,cluster_columns = T,column_split = column_split,
  column_title = column_names,
  column_gap = unit(2, "mm"), border = TRUE,show_parent_dend_line = FALSE, show_column_dend = F,cluster_column_slices = F)

  
p
```

```{r fig.width=10}
# only nmf programs
for (patient_name in unique(xeno$orig.ident)) {
  
  patient_data = subset(xeno,subset = orig.ident == patient_name)
  pathways_names = c("HALLMARK-INTERFERON-ALPHA-RESPONSE","HALLMARK-TNFA-SIGNALING-VIA-NFKB", "HALLMARK-HYPOXIA","HALLMARK-E2F-TARGETS" )
  
  DefaultAssay(patient_data) = "sipsic"
  data = FetchData(object = patient_data, vars = c(pathways_names))
  data[] <- data %>% 
    mutate(across(everything(), ~ as.numeric(scale(.))))  # scale per pathway
  data = data %>% t() %>% as.data.frame()
  
  annotation_data = FetchData(object = patient_data, vars = c("treatment")) %>% dplyr::arrange(treatment)
  column_ha = HeatmapAnnotation(Treatment = annotation_data[,1], #set annotation
                                col = list(Treatment = c("NT" = "red", "OSI" = "green", "res" = "blue"))) 
  data = data[,rownames(annotation_data)] #order data like annotation
  data = na.omit(data)
  DefaultAssay(xeno) = "RNA" #make RNA default again
  
  p = ComplexHeatmap::Heatmap(
    data,
    show_column_names = F,
    row_names_gp = grid::gpar(fontsize = 10),
    cluster_rows = T,
    top_annotation = column_ha,
    name = "Z-score expression",use_raster = F,cluster_columns = T,column_split = annotation_data$treatment,
    column_gap = unit(2, "mm"), border = TRUE,show_parent_dend_line = FALSE, show_column_dend = T,cluster_column_slices = F,column_title = patient_name)
  
    
  print(p)
}
```


# Correlation

```{r}
# Description
for (patient_name in unique(xeno$orig.ident)) {
  
  patient_data = subset(xeno, subset = orig.ident == patient_name)
  pathways_names = c(
    "HALLMARK-INTERFERON-ALPHA-RESPONSE",
    "HALLMARK-TNFA-SIGNALING-VIA-NFKB",
    "HALLMARK-HYPOXIA",
    "HALLMARK-E2F-TARGETS"
  )
  
  DefaultAssay(patient_data) = "sipsic"
  data = FetchData(object = patient_data, vars = c(pathways_names))
  data[] <- data %>%
    mutate(across(everything(), ~ as.numeric(scale(.))))  # scale per pathway
  
  
  data = na.omit(data)
  DefaultAssay(xeno) = "RNA" #make RNA default again
  colnames(data) = c("H_INFa", "H_TNFa_NFKb", "H_HYPOXIA", "H_E2F")
  library(circlize)
  data = cor(data)
  col_fun = colorRamp2(c(-1, 0, 1), c("blue", "white", "red"))
 p =  Heatmap(
    data, name = "pearson", col = col_fun, show_row_names = F, column_title = patient_name,
    cell_fun = function(j, i, x, y, width, height, fill) {
      grid.text(as.character(round(data[i, j], digits = 2)), x, y, gp = gpar(fontsize = 10))
    }
  )
 print(p)
}
```


# Ternary plot

```{r}
# Description
library(ggtern)
p_list = list()

for (patient_name in unique(xeno$orig.ident)) {
  patient_data = subset(xeno,subset = orig.ident == patient_name)
  pathways_names = c(
    "HALLMARK-INTERFERON-ALPHA-RESPONSE",
    "HALLMARK-TNFA-SIGNALING-VIA-NFKB",
    "HALLMARK-HYPOXIA"
  )
  
  DefaultAssay(patient_data) = "sipsic"
  data = FetchData(object = patient_data, vars = c(pathways_names))
  data[] <- data %>%
    mutate(across(everything(), ~ as.numeric(min_max_normalize(.))))  # scale per pathway
  data = data[colnames(patient_data)[patient_data$treatment == "OSI"],]
  # data = apply(data, MARGIN = 2, min_max_normalize) %>% as.data.frame()
  
  colnames(data) = c("IFNa","TNFa_NFKb","HIF")
  

  p = ggtern(data,ggtern::aes(IFNa,TNFa_NFKb,HIF)) +geom_point()+
  ggtitle(paste("Model",patient_name))+
  theme_tropical(base_size=14)
  

  p_list[[patient_name]] = p

}

```


```{r}
# Description
library(ggtern)
p_list = list()

for (patient_name in unique(xeno$orig.ident)) {
  # patient_name = "119"
  patient_data = subset(xeno,subset = orig.ident == patient_name)
  pathways_names = c(
    "HALLMARK-INTERFERON-ALPHA-RESPONSE",
    "HALLMARK-TNFA-SIGNALING-VIA-NFKB",
    "HALLMARK-HYPOXIA"
  )
  
  DefaultAssay(patient_data) = "sipsic"
  data = FetchData(object = patient_data, vars = c(pathways_names))
  # data[] <- data %>%
  #   mutate(across(everything(), ~ as.numeric(min_max_normalize(.))))  # scale per pathway
  data$treatment = patient_data$treatment
  colnames(data) = c("IFNa","TNFa_NFKb","HIF","treatment")
  

  p = ggtern(data,ggtern::aes(IFNa,TNFa_NFKb,HIF)) +
geom_point(ggtern::aes(fill=treatment,shape=treatment),color='black') +
scale_shape_manual(values=c(21,22),breaks = c("OSI"))+
    ggtitle(paste("Model",patient_name))+
  theme_tropical(base_size=14)
    

  p_list[[patient_name]] = p

}

```
```{r}
# Description
View(p1$data)
p_list
```

```{r}

# Description
df = data.frame(x=c(0.8,0.06),y=c(0.2,0.87),z=c(0.1,0.03))
labFnc <- function(x,digits=2) format(round(unique(x),digits),digits=digits)
breaks = seq(from = 0, to = 1, by = 0.1)
p1 = ggtern(data=df,ggtern::aes(x,y,z)) + geom_point()+
  theme_tropical(base_size=14) +
  scale_T_continuous(breaks=unique(df$y),labels = labFnc(df$y)) +
  scale_L_continuous(breaks=unique(df$x),labels=labFnc(df$x)) +
  scale_R_continuous(breaks=unique(df$z),labels=labFnc(df$y)) 

crd = coord_tern()
df
debugonce(tlr2xy)
tlr2xy(df,crd,scale = F)


debugonce(coord_tern)

  ggplot(data = Feldspar, mapping = ggtern::aes(Ab,An,Or)) + coord_tern(Tlim  = c(0,0.2),Llim = c(0,0.5))


ggtern(data=Feldspar,ggtern::aes(Ab,An,Or)) + 
  geom_point(ggtern::aes(fill=Feldspar,shape=Feldspar,size=P.Gpa),color='black') + 
  scale_shape_manual(values=c(21,22),breaks = c("Alkalai"))
```

```{r fig.height=10, fig.width=15}
# plot
do.call(ggtern::grid.arrange,args = c(p_list,ncol=3))
```


